package com.macro.mall.bo;

import com.macro.mall.model.UmsAdmin;
import com.macro.mall.model.UmsResource;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.authority.SimpleGrantedAuthority;
import org.springframework.security.core.userdetails.UserDetails;

import java.util.Collection;
import java.util.List;
import java.util.stream.Collectors;

/**
 * @author Administrator
 * @date 2020/6/8
 * @since
 */
public class AdminUserDetails implements UserDetails {
	private UmsAdmin umsAdmin;
	private List<UmsResource> resourceList;
	public AdminUserDetails(UmsAdmin umsAdmin,List<UmsResource> resourceList) {
		this.umsAdmin = umsAdmin;
		this.resourceList = resourceList;
	}

	@Override
	public Collection<? extends GrantedAuthority> getAuthorities() {
		return resourceList.stream()
			.map(role -> new SimpleGrantedAuthority(role.getId()+":"+role.getName()))
			.collect(Collectors.toList());
	}

	@Override
	public String getPassword() {
		return umsAdmin.getPassword();
	}

	@Override
	public String getUsername() {
		return umsAdmin.getUsername();
	}

	@Override
	public boolean isAccountNonExpired() {
		return true;
	}

	@Override
	public boolean isAccountNonLocked() {
		return true;
	}

	@Override
	public boolean isCredentialsNonExpired() {
		return true;
	}

	@Override
	public boolean isEnabled() {
		return umsAdmin.getStatus().equals(1);
	}

}
